



P- 3376



INVESTOR IN PEOPLE

## CERTIFIED COPY OF PRIORITY DOCUMENT

The Patent Office  
Concept House  
Cardiff Road  
Newport  
South Wales  
NP10 8QQ

I, the undersigned, being an officer duly authorised in accordance with Section 74(1) and (4) of the Deregulation and Contracting Out Act 1994, to sign and issue certificates on behalf of the Comptroller-General, hereby certify that annexed hereto is a true copy of the documents as originally filed in connection with the patent application identified therein together with the statement of inventorship and of right to grant of a Patent (Form 7/77), which was subsequently filed.

In accordance with the Patents (Companies Re-registration) Rules 1982, if a company named in this certificate and any accompanying documents has re-registered under the Companies Act 1985 with the same name as that with which it was registered immediately before re-registration save for the substitution as, or inclusion as, the last part of the name of the words "public limited company" or their equivalents in Welsh, references to the name of the company in this certificate and any accompanying documents shall be treated as references to the name in which it is so re-registered.

In accordance with the rules, the words "public limited company" may be replaced by p.l.c., plc, p.c. or PLC.

Re-registration under the Companies Act does not constitute a new legal entity but merely subjects the company to certain additional company law rules.

Signed

Dated 5 March 2002

**THIS PAGE BLANK (USPTO)**

Statement of inventorship and of  
right to grant of a patent

The Patent Office

Cardiff Road  
Newport  
Gwent NP9 1RH

1. Your reference

GBP12557A

2. Patent application number  
(if you know it)

98 143 79.5

3. Full name of the or of each applicant

LSI LOGIC CORPORATION

4. Title of the invention

DETERMINING TIMING OF  
INTEGRATED CIRCUITS5. State how the applicant(s) derived the right  
from the inventor(s) to be granted a patent

BY VIRTUE OF EMPLOYMENT

6. How many, if any, additional Patents Forms  
7/77 are attached to this form?  
(see note (c))

NONE

7.

I/We believe that the person(s) named over the page (and on  
any extra copies of this form) is/are the inventor(s) of the invention  
which the above patent application relates to.

Signature

MILLER STURT KEYN

Date 29/6/99

MILLER STURT KEYN

8. Name and daytime telephone number of  
person to contact in the United KingdomMR C M STURT  
0171-242-5974

## Notes

- a) If you need help to fill in this form or you have any questions, please contact the Patent Office on 0645 500505.
- b) Write your answers in capital letters using black ink or you may type them.
- c) If there are more than three inventors, please write the names and addresses of the other inventors on the back of another Patents Form 7/77 and attach it to this form.
- d) When an application does not declare any priority, or declares priority from an earlier UK application, you must provide enough copies of this form so that the Patent Office can send one to each inventor who is not an applicant.
- e) Once you have filled in the form you must remember to sign and date it.

Enter the full names, addresses and postcodes of the inventors in the boxes and underline the surnames

WILLIAM ERIC CORR  
12 KNOWLE ROAD  
TWICKENHAM  
MIDDLESEX  
TW2 6QH

7692677001

Patents ADP number (*if you know it*):

Patents ADP number (*if you know it*):

**Reminder**

Have you signed the form?

Patents ADP number (*if you know it*):



9  
03JUL98 1372951-3 D00528  
P01/7700 25.00 9814379.5

## Request for grant of a patent

(See the notes on the back of this form. You can also get an explanatory leaflet from the Patent Office to help you fill in this form)

The Patent Office

Cardiff Road  
Newport  
Gwent NP9 1RH

## 1. Your reference

GBP12557A

## 2. Patent application number

(The Patent Office will fill in this part)

02 JUL 1998

9814379.5

## 3. Full name, address and postcode of the or of each applicant (underline all surnames)

LSI Logic Corporation  
1551 McCarthy Blvd.  
Milpitas, California 95035,  
United States of America

Patents ADP number (if you know it)

7350622001

If the applicant is a corporate body, give the country/state of its incorporation

California, United States of America

## 4. Title of the invention

DETERMINING TIMING OF INTEGRATED CIRCUITS

## 5. Name of your agent (if you have one)

Miller Sturt Kenyon  
9 John Street  
London WC1N 2ES

"Address for service" in the United Kingdom to which all correspondence should be sent (including the postcode)

Patents ADP number (if you know it)

07395486001

## 6. If you are declaring priority from one or more earlier patent applications, give the country and the date of filing of the or of each of these earlier applications and (if you know it) the or each application number

Country

Priority application number  
(if you know it)Date of filing  
(day / month / year)

## 7. If this application is divided or otherwise derived from an earlier UK application, give the number and the filing date of the earlier application

Number of earlier application

Date of filing  
(day / month / year)

## 8. Is a statement of inventorship and of right to grant of a patent required in support of this request? (Answer 'Yes' if:

- a) any applicant named in part 3 is not an inventor, or
- b) there is an inventor who is not named as an applicant, or
- c) any named applicant is a corporate body.

See note (d))

Patents Form 1/77

9. Enter the number of sheets for any of the following items you are filing with this form.  
Do not count copies of the same document

Continuation sheets of this form

| Description | 8    |
|-------------|------|
| Claim(s)    | 2    |
| Abstract    | 1    |
| Drawing(s)  | 4 24 |

10. If you are also filing any of the following, state how many against each item.

Priority documents

Translations of priority documents

Statement of inventorship and right to grant of a patent (Patents Form 7/77)

Request for preliminary examination and search (Patents Form 9/77)

Request for substantive examination  
(Patents Form 10/77)

Any other documents  
(please specify)

11.

I/We request the grant of a patent on the basis of this application.

*Miller Sturt Kenyon*

Signature

Date

Miller Sturt Kenyon

2nd July 1998

12. Name and daytime telephone number of person to contact in the United Kingdom

C. M. Sturt 0171 242-5974

**Warning**

After an application for a patent has been filed, the Comptroller of the Patent Office will consider whether publication or communication of the invention should be prohibited or restricted under Section 22 of the Patents Act 1977. You will be informed if it is necessary to prohibit or restrict your invention in this way. Furthermore, if you live in the United Kingdom, Section 23 of the Patents Act 1977 stops you from applying for a patent abroad without first getting written permission from the Patent Office unless an application has been filed at least 6 weeks beforehand in the United Kingdom for a patent for the same invention and either no direction prohibiting publication or communication has been given, or any such direction has been revoked.

**Notes**

- a) If you need help to fill in this form or you have any questions, please contact the Patent Office on 0645 500505.
- b) Write your answers in capital letters using black ink or you may type them.
- c) If there is not enough space for all the relevant details on any part of this form, please continue on a separate sheet of paper and write "see continuation sheet" in the relevant part(s). Any continuation sheet should be attached to this form.
- d) If you have answered 'Yes' Patents Form 7/77 will need to be filed.
- e) Once you have filled in the form you must remember to sign and date it.
- f) For details of the fee and ways to pay please contact the Patent Office.

## DETERMINING TIMING OF INTEGRATED CIRCUITS

The present invention relates to a method and means for determining timings of operation of the various elements in a synchronous integrated circuit.

Static timing analysis tools are usually constructed as program that runs on a computer system which reads and writes information from a database which contains information on the logical and physical construction of an integrated circuit. This type of program is typically referred to as a "design tool".

Conventional static timing analysis tools determine whether storage devices will work reliably by looking at the predicted timing delays between their clock and data pins switching. If the difference in time between the signal switching at the pins is smaller than the device can tolerate, it may become "metastable", that is its output becomes indeterminate which would cause problems for other circuit elements and unreliable system operation.

The disadvantage of such tools is that they assume that all signal propagate around the die of an integrated circuit with a speed that is governed only by the dimensions of the wire and the strength of the driving element. Unfortunately, in complex integrated circuits this is not strictly true. Many wires cross or run parallel to each signal wire, and any switching activity in these wires may perturb the flight time of a signal in the victim wire. This effect is known as "crosstalk" and is a dynamic effect. It depends on switching activity. Conventional timing analysis is static, it does not require any switching information to determine whether or not the integrated storage elements will work reliably. Thus, it is open to making incorrect assumptions about the time signals take to travel around the chip and will not reliably predict which paths really are likely to cause timing problems.

## SUMMARY OF THE INVENTION

It is an object of the invention to provide a method and means for improving the operation of synchronous integrated circuits and alleviating the effects of dynamic crosstalk.

In the first aspect, the present invention provides a method of determining the timing for a synchronous integrated circuit, the circuit including a multiplicity of clocked elements interconnected by signal paths, the method comprising:

- 1) forming predictions for timing delays in said signal paths in the integrated circuit;
- 2) selecting a first such path, tracing wires in the integrated circuit forming the path (hereinafter referred to as victim wires) and determining adjacent and crossing wires thereto (hereinafter referred to as aggressor wires);
- 3) for each aggressor wire, determining the amount of perturbation coupling to the victim wires of the first path;
- 4) dividing the aggressor wires into a plurality of categories depending on the clocked timing of the aggressor wires in relation to the clocked timing of the victim wires;
- 5) adding margins of error to the clocked timing of the victim wires in dependence upon the number of aggressor wires in one or more of said categories.

In a second aspect, the present invention provides apparatus for determining the timing of a synchronous integrated circuit, the circuit including a multiplicity of clocked elements interconnected by signal paths, the apparatus comprising:

- 1) means for forming predictions for timing delays in said signal paths in the integrated circuit;
- 2) means for selecting a first such path, tracing wires in the integrated circuit forming the path (hereinafter referred to as victim wires) and determining adjacent and crossing wires thereto (hereinafter referred to as aggressor wires);

3) means for determining the amount of coupling, for each aggressor wire, to the victim wires of the first path;

4) means for dividing the aggressor wires into a plurality of categories depending on the clocked timing of the aggressor wires in relation to the clocked timing of the victim wires;

5) means for adding margins of error to the clocked timing of the victim wires in dependence upon the number of aggressor wires in one or more of said categories.

#### **BRIEF DESCRIPTION OF THE DRAWINGS**

A preferred embodiment of the invention will now be described with reference to the accompanying drawings wherein:

Figure 1 is a commonly used timing diagram for a clocked element for a known method of static timing analysis;

Figure 2 is a conceptual diagram of aggressor wires or nets crossing a victim wire or net, in accordance with the invention;

Figure 3 is a conceptual timing diagram similar to figure 1 but with additional margins added for the clocked timing relationship in accordance with the present invention; and

Figures 4, 5 and 6 are flow-charts of the method in accordance with the invention.

#### **DESCRIPTION OF THE PREFERRED EMBODIMENT**

Referring to figure 1, a clocked element 2, e.g. a flip-flop, has a data line 4 and a clock line 6.

As is usual, if data is to be applied on line 4 to the element 2, the data is presented on line 4 well before the occurrence of the clock signal on line 6 in order to ensure that variations in timing do not cause incorrect operation. As can be seen, there is to the left of the rising edge of the clock pulse a time margin based on the set-up time for the circuit, and a time margin to the right of the rising edge of the clock pulse known as the hold time critical region in which operation of element 2 should take place with

data present on line 4 and a clock pulse on line 6. Data should be present on line 6 throughout this period.

The apparatus in accordance with the invention, or "tool" operates in several phases, looking at all parts in an integrated circuit which include elements such as that shown in figure 1, and the time it takes for signals to travel from one pin of one element to the next.

In accordance with the invention, the topological nature of each signal path is examined, as indicated in figure 2, wherein the signal path comprises a wire between components 10, 12, each wire being referred to as victim wire, and the combination of victim wires being referred to as a victim net 14. The victim net is examined, looking at the number of "aggressor wires" 16 crossing and/or running parallel to the victim net to determine the amount of perturbation clocked signals in the aggressor wires would have on the victim net, should the aggressor wires switch at exactly the same time as a signal being transmitted in the victim net.

The actual amount of perturbation (a static timing analysis) is calculated based on the following criteria:

- 1) Topology of the coupling, i.e. are the wires crossing or in parallel
- 2) The layer in the semiconductor chip that the wires are on
- 3) The strength or power of the drivers in the victim and aggressor nets
- 4) The operating conditions such as process, voltage and temperature
- 5) The nature of the wire - static/power supply/dynamic

Static wires would have no effect so can be discounted from the list. Dynamic wires do have an effect so must be analysed, in terms of their switching in relation to the victim wire. Power supply wires may have an effect. This is hard to quantify due to the complex nature of the switching of the cells attached to the power nets, so for a first order approximation it will be assumed that they do not have any effect.

This gives a worst case situation that assumes each crossing wire is going to cause the maximum amount of impact to the victim wire. This is too pessimistic as it is unlikely that each aggressor wire will switch at exactly the right time to cause

perturbation. Therefore, a further processing phase is required to post-process these predictions.

The final phase looks at each aggressor wire and makes an attempt to classify how likely this wire is going to perturb the victim wire. A possible categorisation strategy might be:

Very likely: delay prediction indicates that the aggressor wire may toggle at the same time as the victim wire and that there are few other aggressor wires crossing this aggressor wire so it is fairly certain that it will switch at this time (assumptions are made to make it a first order approximation. Any more would make run times excessive).

Possible: delay prediction indicates that the aggressor wire may toggle at a time near to the victim wire, but the number of aggressor wires crossing this aggressor wire make it hard to predict exactly when it will switch.

Unlikely: Aggressor wire is on a net that cannot switch at a time where it will perturb the victim wire.

Once the categorisation has finished, these effects can be back-annotated onto the traditional static timing analysis as shown in figure 3. The degree of effect very likely...possible could be selected by the user to trade run times against accuracy.

As indicated in figure 3, the categorisation of the aggressor wires leads to the adding of additional margins 30 to the set-up time margin and the hold time critical region margin on either side of the rising edge of the clock pulse.

Referring now to the flow chart shown in figures 4, 5 and 6, figure 4 shows a general method of operation in accordance with the invention wherein in a first step 40, the various clocked paths in the integrated circuit are determined from a logic data base, each path being termed a signal path or victim net.

In step 42, the delay for a clock pulse passing through the signal path is determined, based on the characteristics of the signal path itself, without reference to external effects.

In step 44, a first signal path is selected, and in step 46 the wires (victim wires) forming the signal path are traced in a layout database of the integrated circuit and adjacent and crossing wires are determined, such wires being defined as aggressor wires.

In step 48, the amount of coupling for each adjacent wire is determined to the victim wires, based on an assumption that clocking occurs in the aggressor wire at the same time as in the victim wire.

In step 50, this procedure is repeated for each signal path in the data base.

In step 52, the aggressor nets are posted into categories for likelihood of affecting switching in the victim wire. In step 54, a timing analysis is carried out, as indicated above with reference to figure 2.

In step 56, the degree of accuracy for timing is selected, and in step 58 the static timing analysis results are modified to add margins based on the effects of aggressor nets in selected categories.

Step 52 is shown in more detail in figure 5. In step 60, it is determined whether in practice the aggressor net will switch at a different time to the victim wires. If the answer is YES, the aggressor wire is posted or flagged as "not likely" to effect the timing of the victim wires as at 62.

If the answer to determination at step 60 is NO, a further determination is made as to whether the aggressor net switches at a time close to the victim net, but because of the presence of other aggressor nets, it is not possible to make an accurate determination of delay prediction. If the answer to this determination is YES, then the aggressor wire is determined as "possible" as at 66, in that it may possibly effect the timing of the victim wires.

If the answer to the determination in step 64 is NO, then a further determination is made as to whether the aggressor net switches at a time close to the victim net, if the answer to this determination is YES, then the aggressor net is flagged or posted as in "likely", as at 70, to effect the timing of the victim net. If the answer to this determination is NO, then the aggressor net is posted as "not likely" to effect the timing of the victim net, as at 72.

This process is repeated for each aggressor net for any particular victim net, with the result that the aggressor nets are posted into three categories, "likely", "possible", or "not likely" to effect the timing of the victim net.

As shown in figure 6, steps 56 and 58 of figure 4 are shown in more detail in that margins are added to the clock timing of the victim wire in two selected ranges of accuracy. If as at 80, the analysis mode is set to pessimistic, and all significant effects on timing are to be taken into account, then an interval of time delta is added to the margins indicated in figure 3, as at 82, based on predicted perturbation from "likely" and "possible" data sets. If however the only the most significant perturbances are to be taken into account, i.e. a less accurate method of timing analysis, then as at 84, the analysis mode is set to normal, and as at 86 a time interval delta is added to the margins indicated in figure 3 based on the predicted perturbation from the "likely" data set, as determined in figure 5.

As indicated at 88, if no aggressor net perturbances are to be taken into account, then no timing interval is added to the margins of figure 3.

It will be understood that the predicted perturbation to be added to the timing interval will depend on the number of aggressor nets in the "likely" and "possible" data sets and thus the time interval to be added to the margin for timing will be extended based upon known statistical analysis methods. The effect of the number of aggressor nets would be scaled based on the topological and electrical nature of the coupling between two wires. For example, one aggressor wire that is driven by a strong source, such as a clock buffer running parallel a victim wire would have more effect than many aggressor wires running perpendicular to the victim wire (because the parallel wire will have a large coupling). This scaling can be calculated quite simply (for first order approximations), the coupling effect is capacitive and may formulae exist for calculating approximations for wires in different topological configurations.

The electrical impact can be calculated (again as a first order approximation) by using electrical circuit theory, the coupling capacitance and the knowledge of the signal's

propagation rate from the design tools' delay predictions that make the starting point for the static analysis algorithms.

It will be understood that the method illustrated in figure 4, 5 and 6 will be carried out on a computer system of the type used in analysis of integrated circuits and that the computer system will have modules added to it corresponding to the various method steps illustrated in figures 4, 5 and 6. Thus, the method disclosed in figures 4 to 6 is equivalent to the disclosure of the apparatus modules to be added to the computer system.

**Claims:**

1. A method of determining the timing for a synchronous integrated circuit, the circuit including a multiplicity of clocked elements interconnected by signal paths, the method comprising:

- 1) Forming predictions for timing delays in said signal paths in the integrated circuit;
- 2) Selecting a first such path, tracing wires in the integrated circuit forming the path (hereinafter referred to as victim wires) and determining adjacent and crossing wires thereto (hereinafter referred to as aggressor wires);
- 3) For each aggressor wire, determining the amount of perturbation coupling to the victim wires of the first path;
- 4) Dividing the aggressor wires into a plurality of categories depending on the clocked timing of the aggressor wires in relation to the clocked timing of the victim wires;
- 5) Adding margins of error to the clocked timing of the victim wires independence upon the number of aggressor wires in one or more said categories.

2. A method according to claim 1, wherein step (3) is carried out taking into account one or more of the following factors:

- a) whether the aggressor wire crosses or runs parallel to the victim wire;
- b) the signal strengths in the victim and aggressor wires;
- c) the layers in the integrated circuit which the wires are disposed;
- d) operating conditions; and
- e) the nature of aggressor wire

3. A method according to claim 1 or 2, wherein the aggressor wires are divided into three categories of likely, possible or unlikely to affect the timing of the victim wire.

4. A method according to claim 3, wherein the effect only of the likely category are taken into account.
5. A method according to claim 3, wherein the effect of the likely and possible categories are taken into account.
6. A method according to claim 3, wherein the effect of none of the categories is taken into account.
7. A method according to any of claims 3 to 6, wherein the effects of aggressor wires in any category are scaled according to their respective topological coupling and respective electrical signal coupling with the victim wire.
8. Apparatus for determining the timing of a synchronous integrated circuit, the circuit including a multiplicity of clocked elements interconnected by signal paths, the apparatus comprising:
  - 1) Means for forming predictions for timing delays in said signal paths in the integrated circuit;
  - 2) Means for selecting a first such path, tracing wires in the integrated circuit forming the path (hereinafter referred to as victim wires) and determining adjacent and crossing wires thereto (hereinafter referred to as aggressor wires);
  - 3) Means for determining the amount of coupling, for each aggressor wire, to the victim wires of the first path;
  - 4) Means for dividing the aggressor wires into a plurality of categories depending on the clocked timing of the aggressor wires in relation to the clocked timing of the victim wires;
  - 5) Means for adding margins of error to the clocked timing of the victim wires independence upon the number of aggressor wires in one or more said categories.

## ABSTRACT

### DETERMINING TIMING OF INTEGRATED CIRCUITS

A method of determining the timing of signal paths in a synchronous integrated circuit, taking into account the perturbing effect of switching in adjacent signal paths, the method comprising:

- 1) Forming predictions for timing delays in signal paths in the integrated circuit;
- 2) Selecting a first such path, tracing wires in the integrated circuit forming the path (victim wires) and determining adjacent and crossing wires thereto (aggressor wires);
- 3) For each aggressor wire, determining the amount of perturbation coupling to the victim wires of the first path;
- 4) Dividing the aggressor wires into a plurality of categories depending on the clocked timing of the aggressor wires in relation to the clocked timing of the victim wires;
- 5) Adding margins of error to the clocked timing of the victim wires in dependence upon the number of aggressor wires in one or more said categories.

Fig. 4

**THIS PAGE BLANK (USPTO)**



THIS PAGE BLANK (USPTO)



Figure 4

THIS PAGE BLANK (USPTO)

3/4



SHANE

**THIS PAGE BLANK (USPTO)**



**THIS PAGE BLANK (USPTO)**